<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #num {
            width: 200px;
            height: 200px;
            background-color: springgreen;
        }
    </style>
</head>

<body>
    <div id="num">0</div>
    <script>
        // 1.防抖:函数在特定时间内不再执行后被调用
        // 2.节流:函数在特定的时间内只多执行一次

        // 触发事件后,在n秒内只执行一次,如果重复触发了,时间会重新计算

        let numEle = document.querySelector('#num');
        let num = 0;

        function addNum() {
            numEle.innerText = num++
        };
        // 绑定移动事件--鼠标稍微移动就会重复执行,开销很大
        // numEle.onmousemove = addNum;
        // 定义防抖的函数
        function fandou(fn, time) {
            let timerId = null;
            return function() {
                if (timerId) {
                    clearTimeout(timerId);
                }
                // 执行一次
                timerId = setTimeout(() => {
                    fn();
                }, time)
            }

        };

        numEle.onmousemove = fandou(addNum, 1000);
    </script>
</body>

</html>